This is Kara’s first pass at analyzing the Spiritual Epidemiology data (with data from 2019-03-08). (Note: PDF printed portrait, 90% zoom, default margins.)
Porosity
For Spiritual Epidemiology, the Porosity scale consisted of 16 basic items, and follow-up questions to a subset of these items. For each of the basic items, participants could respond by saying “it does not happen” (scored as 0), “it might happen” (scored as 0.5), or “it definitely happens” (scored as 1).
Overall scores
First, I’ll examine overall “scores” on this scale, taking into account only the basic items (not the follow-up questions). Scores could range from 0 (equivalent to saying “it does not happen” for all 16 items) to 16 (equivalent to saying “it definitely happens” for all 16 items).

From these plots, it is clear that while there was substantial variability across individuals within each site, participants’ average response also varied fairly dramatically across sites, with participants in China endorsing the fewest items, participants in the US and Thailand endorsing slightly more, and participants in Ghana and Vanuatu endorsing the most.
Comparing porosity scores across sites [model: lm(score ~ epi_ctry, d_por_scored)]
| parameter |
b |
standard error |
t |
p |
significant |
| (Intercept) |
6.83 |
0.10 |
71.29 |
<0.001 |
* |
| epi_ctrynonUS_US |
0.55 |
0.05 |
12.06 |
<0.001 |
* |
| epi_ctryGHVT_THCH |
4.13 |
0.11 |
38.00 |
<0.001 |
* |
| epi_ctryGH_VT |
0.04 |
0.15 |
0.31 |
0.76 |
|
| epi_ctryTH_CH |
0.91 |
0.16 |
5.68 |
<0.001 |
* |
Comparing porosity responses across sites [model: lmer(response ~ epi_ctry + (1 | epi_subj) + (epi_ctry | question)]
| parameter |
b |
standard error |
df |
t |
p |
significant |
| (Intercept) |
0.57 |
0.04 |
21.27 |
15.68 |
<0.001 |
* |
| epi_ctrynonUS_US |
0.06 |
0.01 |
26.30 |
6.67 |
<0.001 |
* |
| epi_ctryGHVT_THCH |
0.37 |
0.04 |
24.87 |
10.32 |
<0.001 |
* |
| epi_ctryGH_VT |
-0.09 |
0.03 |
30.97 |
-3.11 |
0.004 |
* |
| epi_ctryTH_CH |
0.08 |
0.02 |
199.27 |
5.19 |
<0.001 |
* |
I ran two kinds of statistical analyses of these results: One comparing these average scores across sites (top table), and the other taking into account variability across individual participants and across individual items in the scale (bottom table). Theoretically, these analyses should yield pretty similar results, so I would be especially confident in effects that are consistent across the two analyses and that seem obvious from the plots.
Both analyses suggest that participants in sites outside of the US generally had significantly higher Porosity scores than participants in the US (see “epi_ctrynonUS_US” rows)—but looking at the plots it is clear that this was driven by participants in Ghana and Vanuatu, and was not true, on average, among participants in Thailand or China. In line with this, both analyses suggest that participants in Ghana and Vanuatu had significantly higher Porosity scores than participants in Thailand and China—and that this difference was far greater than the difference between “the West vs. the rest” (see “epi_ctrynonUS_US” rows). Both analyses also suggest that participants in Thailand had significantly higher Porosity scores, on average, than participants in China (see “epi_ctryTH_CH” rows).
By item
Next, I’ll examine responses to individual items on the Porosity scale, first focusing on the basic items and then turning to the follow-up questions and a few site-specific questions. For each item, participants could say “it does not happen” (scored as 0), “it might happen” (scored as 0.5), or “it definitely happens” (scored as 1).

There is so much to unpack here! When I look at these items, a few things that I think about are:
- Which items tend to follow the overall pattern established by the “overall scores” presented in the previous section? (e.g., question #1, many others)
- Among items that follow the overall pattern, for which items is this pattern exaggerated? (e.g., questions #5, #12) For which items is this pattern attentuated? (e.g., quesitons #2, #3)
- Which items do not follow this overall trend? (e.g., question #16)
- Which items seem to pick out an experience that is uniquely salient/prevalent in a particular site? (e.g., questions #7, #16)
Note that I just picked out a few examples to illustrate what I mean, but there are certainly other interesting cases that might be worth thinking about more deeply - e.g., question #15, where US participants appear more like Ghanaian & ni-Van participants than Thai or Chinese participants).
Here are participants’ answers to the follow-up questions for a subset of those basic items:

And here are participants’ answers to a few site-specific questions:

Prayer (spiritual experience Question #1)
For Spiritual Epidemiology, the “spiritual experience” portion of the epidemiology began with two questions intended to gauge participants’ prayer practice. Here are participants’ responses to these two questions:

All spiritual experiences (Questions #2-23)
For Spiritual Epidemiology, the Spiritual Experiences scale consisted of 22 basic items (34 basic items in Thailand), and follow-up questions to a subset of these items. For each of the basic items, participants could respond by saying “no” (scored as 0), “maybe” (scored as 0.5; this might have only been available in some sites?), or “yes” (scored as 1).
Note: In addition to these 22 items, there were two items included as part of this section on “spiritual experiences” that were intended to gauge participants’ prayer practice - see Prayer (spiritual experience Question #1), above.
Overall scores
First, I’ll examine overall “scores” on this scale, taking into account only the basic items (not the follow-up questions).
In Thailand, there were an additional 12 quesitons (about experiences of additional “beings”) that; I have treated this discrepancy across sites in two different ways below: (1) Consdering all beings and using proportions, rather than sums, as “scores” (equivalent to asking, for each particiant, what proportion of the items they were exposed to did they endorse?); and (2) Considering only the first 5 beings asked about in each site, such that all participants were asked the same number of questions.
Considering all “beings”
Using the first approach (considering all “beings,” with 12 more beings in Thailand than in any other site), scores could range from 0 (equivalent to saying “no” for all 22-34 items) to 1 (equivalent to saying “yes” for all 22-34 items).

From these plots, it is clear that while there was substantial variability across individuals within each site, participants’ average response also varied fairly dramatically across sites, with participants in China endorsing the fewest items, participants in the US and Thailand endorsing slightly more, and participants in Ghana and Vanuatu endorsing the most. This is the same pattern we observed for Porosity scores, above.
Comparing spiritual experience scores across sites [model: lm(score ~ epi_ctry, d_spex_base_q2to23_scored_propall)]
| parameter |
b |
standard error |
t |
p |
significant |
| (Intercept) |
0.28 |
0.01 |
50.72 |
<0.001 |
* |
| epi_ctrynonUS_US |
0.01 |
0.00 |
3.72 |
<0.001 |
* |
| epi_ctryGHVT_THCH |
0.10 |
0.01 |
15.72 |
<0.001 |
* |
| epi_ctryGH_VT |
-0.04 |
0.01 |
-4.57 |
<0.001 |
* |
| epi_ctryTH_CH |
0.07 |
0.01 |
7.77 |
<0.001 |
* |
Comparing spiritual experience responses across sites [model: lmer(response ~ epi_ctry + (1 | epi_subj) + (epi_ctry | question), d_spex_base_q2to23)]
| parameter |
b |
standard error |
df |
t |
p |
significant |
| (Intercept) |
0.24 |
0.02 |
49.88 |
9.83 |
<0.001 |
* |
| epi_ctrynonUS_US |
0.00 |
0.01 |
34.43 |
0.75 |
0.461 |
|
| epi_ctryGHVT_THCH |
0.10 |
0.02 |
32.57 |
5.60 |
<0.001 |
* |
| epi_ctryGH_VT |
-0.05 |
0.03 |
29.37 |
-1.91 |
0.067 |
|
| epi_ctryTH_CH |
0.06 |
0.02 |
39.19 |
3.06 |
0.004 |
* |
Again, I ran two kinds of statistical analyses of these results: One comparing these scores across sites (top table), and the other taking into account variability across individual participants and across individual items in the scale (bottom table). Theoretically, these analyses should yield pretty similar results, so I would be especially confident in effects that are consistent across the two analyses and that seem obvious from the plots.
Both analyses suggest that participants in sites outside of the US generally had significantly higher Porosity scores than participants in Ghana and Vanuatu had significantly higher Porosity scores than participants in Thailand and China (see “epi_ctrynonUS_US” rows), and that participants in Thailand had significantly higher Porosity scores, on average, than participants in China (see “epi_ctryTH_CH” rows).
Considering first five “beings” only
Using the second approach (considering only the first five “beings” in each site), scores could range from 0 (equivalent to saying “no” for all 22 items) to 22 (equivalent to saying “yes” for all 22 items).

These plots look very similar to the plots considering all beings (which I find reassuring).
Comparing spiritual experience scores across sites [model: lm(score ~ epi_ctry, d_spex_base_q2to23_scored_first5)]
| parameter |
b |
standard error |
t |
p |
significant |
| (Intercept) |
6.19 |
0.12 |
50.60 |
<0.001 |
* |
| epi_ctrynonUS_US |
0.23 |
0.06 |
3.86 |
<0.001 |
* |
| epi_ctryGHVT_THCH |
2.08 |
0.14 |
14.97 |
<0.001 |
* |
| epi_ctryGH_VT |
-0.90 |
0.19 |
-4.82 |
<0.001 |
* |
| epi_ctryTH_CH |
1.73 |
0.20 |
8.45 |
<0.001 |
* |
This pattern of results are identical to the pattern of results considering all beings (which, again, I find reassuring).
In the following four sections (Spiritual experiences: Universal questions, set 1 (Questions #2-10), Spiritual experiences: Beings questions (Questions #11-15 + more for Thailand), Spiritual experiences: Universal questions, set 2 (Questions #16-21), and Spiritual experiences: Universal questions, set 3 (Questions #22-23)), I look at scores for sub-sections of the Spiritual Experience scale, and at responses to individual items in this scale, including follow-up items. I do not provide text commentary on these additional plots and analyses at this time, but they all follow the same logic as the plots and analyses that I have annotated above.
Spiritual experiences: Universal questions, set 1 (Questions #2-10)
Overall scores

By item

Spiritual experiences: Beings questions (Questions #11-15 + more for Thailand)
Overall scores
Considering all “beings” (more for Thailand)
Removed 1 rows containing missing values (geom_point).

Considering first five “beings” only

By item

Spiritual experiences: Universal questions, set 2 (Questions #16-21)
Overall scores

By item

Spiritual experiences: Universal questions, set 3 (Questions #22-23)
Overall scores

By item

Relationships between porosity and spiritual experience
Finally, I will consider the relationship between Porosity scores and Spiritual Experience scores, comparing this relationship across sites and examining this relationship within each site indivdidually. Again, I will explore two ways of handling the discrepancy between questions asked in Thailand vs. other sites.
Considering all “beings” (more for Thailand)

From the plot, it is clear that there is a general relationship between Porosity and Spiritual Experience scores. The strength of this relationships appears to vary somewhat across sites, but visual inspection suggests that this relationship is present to some degree in each site individually.
First, I’ll look at this relationship considering all sites in the same analysis (standardizing scores collapsing across all sites, to maintain the pattern fo general differences in Porosity and Spiritual Experience across sites):
Relationship between porosity and spiritual experience, comparing across sites [model: lm(por_score_std_collapse ~ spex_score_propall_std_collapse * epi_ctry, d_por_spex_base_q2to23_propall)]
| parameter |
b |
standard error |
t |
p |
significant |
| (Intercept) |
0.03 |
0.02 |
1.44 |
0.151 |
|
| spex_score_propall_std_collapse |
0.40 |
0.02 |
18.98 |
<0.001 |
* |
| epi_ctrynonUS_US |
0.10 |
0.01 |
12.14 |
<0.001 |
* |
| epi_ctryGHVT_THCH |
0.64 |
0.02 |
27.04 |
<0.001 |
* |
| epi_ctryGH_VT |
0.08 |
0.03 |
2.93 |
0.003 |
* |
| epi_ctryTH_CH |
-0.04 |
0.04 |
-0.95 |
0.344 |
|
| spex_score_propall_std_collapse:epi_ctrynonUS_US |
-0.03 |
0.01 |
-2.85 |
0.005 |
* |
| spex_score_propall_std_collapse:epi_ctryGHVT_THCH |
-0.15 |
0.02 |
-6.20 |
<0.001 |
* |
| spex_score_propall_std_collapse:epi_ctryGH_VT |
-0.06 |
0.03 |
-2.51 |
0.012 |
* |
| spex_score_propall_std_collapse:epi_ctryTH_CH |
-0.07 |
0.04 |
-1.74 |
0.083 |
|
Including all of the data in a single analysis suggests that, collapsing across sites, the relationship between Porosity and Spiritual Experience scores is significantly positive (see “spex_score_propall_std” row in the table above). However, this relationship appears to be significantly weaker among participants outside of the US than it is among US participants (see “spex_score_propall_std:epi_ctrynonUS_US” row), significantly weaker among participants in Ghana and Vanuatu relative to participants in Thailand and China (see “spex_score_propall_std:epi_ctryGHVT_THCH” row), and significantly weaker among participants in Ghana relative to participants in Vanuatu (see “spex_score_propall_std:epi_ctryGH_VT” row). In other words, the relationship between Porosity and Spiritual Experience seems to have been strongest in the US and Chinese samples, weaker in the ni-Van and Thai samples, and weakest in the Ghanaian sample. (This is true even after accounting for overall differences in porosity and spiritual experience across sites.)

Next, I’ll look at this relationship considering each sites individually in its own analysis (standardizing scores within each site):
Relationship between porosity and spiritual experience, within each site separately [model: lm(por_score_std ~ spex_score_propall_std, d_por_spex_base_q2to23_propall %>% filter(epi_ctry == ...)]
| parameter |
b |
standard error |
t |
p |
significant |
| US |
| (Intercept) |
0.00 |
0.05 |
0.00 |
1 |
|
| spex_score_propall_std |
0.63 |
0.05 |
12.03 |
<0.001 |
* |
| Ghana |
| (Intercept) |
0.00 |
0.06 |
0.00 |
1 |
|
| spex_score_propall_std |
0.29 |
0.06 |
4.75 |
<0.001 |
* |
| Thailand |
| (Intercept) |
0.00 |
0.06 |
0.00 |
1 |
|
| spex_score_propall_std |
0.46 |
0.06 |
7.35 |
<0.001 |
* |
| China |
| (Intercept) |
0.00 |
0.06 |
0.00 |
1 |
|
| spex_score_propall_std |
0.69 |
0.06 |
12.03 |
<0.001 |
* |
| Vanuatu |
| (Intercept) |
0.00 |
0.06 |
0.00 |
1 |
|
| spex_score_propall_std |
0.49 |
0.06 |
7.79 |
<0.001 |
* |
This analysis suggests that the relationship between Porosity and Spiritual Experience is signficantly positive in all five sites considered individually. The regression coefficients (“b” column in the table above) further confirm that the strength of this relationhip varied across sites: It was strongest in China and the US, middling in Vanuatu and Thailand, and weakest (but still significantly positive) in Ghana.
Considering first five “beings” for all sites

Again, it is clear from the plot that there is a general relationship between Porosity and Spiritual Experience scores, and the strength of this relationships appears to vary somewhat across sites.
First, I’ll look at this relationship considering all sites in the same analysis (standardizing scores collapsing across all sites, to maintain the pattern fo general differences in Porosity and Spiritual Experience across sites):
Relationship between porosity and spiritual experience, comparing across sites [model: lm(por_score_std_collapse ~ spex_score_first5_std_collapse * epi_ctry, d_por_spex_base_q2to23_first5)]
| parameter |
b |
standard error |
t |
p |
significant |
| (Intercept) |
0.03 |
0.02 |
1.35 |
0.178 |
|
| spex_score_first5_std_collapse |
0.39 |
0.02 |
18.87 |
<0.001 |
* |
| epi_ctrynonUS_US |
0.10 |
0.01 |
11.92 |
<0.001 |
* |
| epi_ctryGHVT_THCH |
0.65 |
0.02 |
27.01 |
<0.001 |
* |
| epi_ctryGH_VT |
0.08 |
0.03 |
2.96 |
0.003 |
* |
| epi_ctryTH_CH |
-0.06 |
0.04 |
-1.51 |
0.131 |
|
| spex_score_first5_std_collapse:epi_ctrynonUS_US |
-0.03 |
0.01 |
-3.06 |
0.002 |
* |
| spex_score_first5_std_collapse:epi_ctryGHVT_THCH |
-0.14 |
0.02 |
-5.67 |
<0.001 |
* |
| spex_score_first5_std_collapse:epi_ctryGH_VT |
-0.06 |
0.03 |
-2.33 |
0.02 |
* |
| spex_score_first5_std_collapse:epi_ctryTH_CH |
-0.11 |
0.04 |
-2.73 |
0.007 |
* |
This analysis is virtually identical to the parallel analysis using proportion scores, above—with the additional suggestion that the relationship was significantly weaker among participants in Thailand than participants in China (see “spex_score_first5_std:epi_ctryTH_CH” row in table above).

Next, I’ll look at this relationship considering each sites individually in its own analysis (standardizing scores within each site):
Relationship between porosity and spiritual experience, within each site separately [model: lm(por_score_std ~ spex_score_first5_std, d_por_spex_base_q2to23_first5 %>% filter(epi_ctry == ...)]
| parameter |
b |
standard error |
t |
p |
significant |
| US |
| (Intercept) |
0.00 |
0.05 |
0.00 |
1 |
|
| spex_score_first5_std |
0.62 |
0.05 |
11.91 |
<0.001 |
* |
| Ghana |
| (Intercept) |
0.00 |
0.06 |
0.00 |
1 |
|
| spex_score_first5_std |
0.30 |
0.06 |
4.88 |
<0.001 |
* |
| Thailand |
| (Intercept) |
0.00 |
0.06 |
0.00 |
1 |
|
| spex_score_first5_std |
0.44 |
0.06 |
7.02 |
<0.001 |
* |
| China |
| (Intercept) |
0.00 |
0.06 |
0.00 |
1 |
|
| spex_score_first5_std |
0.69 |
0.06 |
12.02 |
<0.001 |
* |
| Vanuatu |
| (Intercept) |
0.00 |
0.06 |
0.00 |
1 |
|
| spex_score_first5_std |
0.49 |
0.06 |
7.85 |
<0.001 |
* |
As with the analysis of proportion scores, this analysis suggests that the relationship between Porosity and Spiritual Experience is signficantly positive in all five sites considered individually, and the regression coefficients (“b” column in the table above) further confirm that this relationhip was strongest in China and the US, middling in Vanuatu and Thailand, and weakest (but still significantly positive) in Ghana.
---
title: "Spiritual epidemiology ANALYSIS (KW first pass)"
subtitle: "Last updated: 2019-04-19"
output:
  html_notebook:
    toc: yes
    toc_depth: 4
    toc_float: yes
always_allow_html: yes
---

This is Kara's first pass at analyzing the Spiritual Epidemiology data (with data from 2019-03-08). (Note: PDF printed portrait, 90% zoom, default margins.)

```{r global_options, include = F}
knitr::opts_chunk$set(fig.width = 4, fig.asp = 0.67,
                      include = F, echo = F)
```

```{r}
library(tidyverse)
library(langcog)
library(psych)
library(readxl)
library(cowplot)
library(lme4)
library(lmerTest)
library(kableExtra)
library(lubridate)

theme_set(theme_bw())
```


```{r}
d_por <- read.csv("./data_wrangled/d_por.csv", row.names = "X") %>%
  mutate(epi_ctry = factor(epi_ctry, levels = c("US", "Ghana", "Thailand", 
                                                "China", "Vanuatu")))

d_por_scored <- read.csv("./data_wrangled/d_por_scored.csv", row.names = "X") %>%
  mutate(epi_ctry = factor(epi_ctry, levels = c("US", "Ghana", "Thailand", 
                                                "China", "Vanuatu")))
```

```{r}
d_prayer <- read.csv("./data_wrangled/d_prayer.csv", row.names = "X") %>%
  mutate(epi_ctry = factor(epi_ctry, levels = c("US", "Ghana", "Thailand", 
                                                "China", "Vanuatu")))
```

```{r}
d_spex_base_q2to23 <- read.csv("./data_wrangled/d_spex_base_q2to23.csv", row.names = "X") %>%
  mutate(epi_ctry = factor(epi_ctry, levels = c("US", "Ghana", "Thailand", 
                                                "China", "Vanuatu")))

d_spex_base_q2to23_scored_propall <- read.csv("./data_wrangled/d_spex_base_q2to23_scored_propall.csv", row.names = "X") %>%
  mutate(epi_ctry = factor(epi_ctry, levels = c("US", "Ghana", "Thailand", 
                                                "China", "Vanuatu")))

d_spex_base_q2to23_scored_first5 <- read.csv("./data_wrangled/d_spex_base_q2to23_scored_first5.csv", row.names = "X") %>%
  mutate(epi_ctry = factor(epi_ctry, levels = c("US", "Ghana", "Thailand", 
                                                "China", "Vanuatu")))
```

```{r}
d_spex_base_q2to10 <- read.csv("./data_wrangled/d_spex_base_q2to10.csv", row.names = "X") %>%
  mutate(epi_ctry = factor(epi_ctry, levels = c("US", "Ghana", "Thailand", 
                                                "China", "Vanuatu")))

d_spex_base_q2to10_scored <- read.csv("./data_wrangled/d_spex_base_q2to10_scored.csv", row.names = "X") %>%
  mutate(epi_ctry = factor(epi_ctry, levels = c("US", "Ghana", "Thailand", 
                                                "China", "Vanuatu")))
```

```{r}
d_spex_base_q11to15 <- read.csv("data_wrangled/d_spex_base_q11to15.csv", row.names = "X") %>%
  mutate(epi_ctry = factor(epi_ctry, levels = c("US", "Ghana", "Thailand", 
                                                "China", "Vanuatu")))

d_spex_base_q11to15_scored <- read.csv("data_wrangled/d_spex_base_q11to15_scored.csv", row.names = "X") %>%
  mutate(epi_ctry = factor(epi_ctry, levels = c("US", "Ghana", "Thailand", 
                                                "China", "Vanuatu")))
```

```{r}
d_spex_base_q16to21 <- read.csv("data_wrangled/d_spex_base_q16to21.csv", row.names = "X") %>%
  mutate(epi_ctry = factor(epi_ctry, levels = c("US", "Ghana", "Thailand", 
                                                "China", "Vanuatu")))

d_spex_base_q16to21_scored <- read.csv("data_wrangled/d_spex_base_q16to21_scored.csv", row.names = "X") %>%
  mutate(epi_ctry = factor(epi_ctry, levels = c("US", "Ghana", "Thailand", 
                                                "China", "Vanuatu")))
```

```{r}
d_spex_base_q22to23 <- read.csv("data_wrangled/d_spex_base_q22to23.csv", row.names = "X") %>%
  mutate(epi_ctry = factor(epi_ctry, levels = c("US", "Ghana", "Thailand", 
                                                "China", "Vanuatu")))

d_spex_base_q22to23_scored <- read.csv("data_wrangled/d_spex_base_q22to23_scored.csv", row.names = "X") %>%
  mutate(epi_ctry = factor(epi_ctry, levels = c("US", "Ghana", "Thailand", 
                                                "China", "Vanuatu")))
```

```{r}
# alternative contrasts for site
contrasts_ctry_eff <- cbind("US" = c(1, 0, 0, 0, -1),
                            "GH" = c(0, 1, 0, 0, -1),
                            "TH" = c(0, 0, 1, 0, -1),
                            "CH" = c(0, 0, 0, 1, -1))

contrasts_ctry_dum <- cbind("GH_US" = c(0, 1, 0, 0, 0),
                            "TH_US" = c(0, 0, 1, 0, 0),
                            "CH_US" = c(0, 0, 0, 1, 0),
                            "VT_US" = c(0, 0, 0, 0, 1))

contrasts_ctry_ctr <- cbind("nonUS_US" = c(-4, 1, 1, 1, 1),
                            "GHVT_THCH" = c(0, 1, -1, -1, 1),
                            "GH_VT" = c(0, 1, 0, 0, -1),
                            "TH_CH" = c(0, 0, 1, -1, 0))
```

# Porosity

For Spiritual Epidemiology, the Porosity scale consisted of 16 basic items, and follow-up questions to a subset of these items. For each of the basic items, participants could respond by saying "it does not happen" (scored as 0), "it might happen" (scored as 0.5), or "it definitely happens" (scored as 1).

## Overall scores

First, I'll examine overall "scores" on this scale, taking into account only the basic items (not the follow-up questions). Scores could range from 0 (equivalent to saying "it does not happen" for all 16 items) to 16 (equivalent to saying "it definitely happens" for all 16 items).

```{r}
d_por_scored_mb <- d_por_scored %>%
  group_by(epi_ctry) %>%
  multi_boot_standard("score") %>%
  ungroup() %>%
  mutate(epi_ctry = factor(epi_ctry, levels = c("US", "Ghana", "Thailand", 
                                                "China", "Vanuatu")))

# effect-code by default
contrasts(d_por_scored$epi_ctry) <- contr.sum(5)
```

```{r, fig.width = 4, fig.asp = 0.6, include = T}
por_plot_a <- ggplot(d_por_scored,
                     aes(x = epi_ctry, y = score, color = epi_ctry)) +
  geom_hline(yintercept = 0*16, lty = 2, color = "black") +
  geom_hline(yintercept = 0.5*16, lty = 2, color = "black") +
  geom_hline(yintercept = 1*16, lty = 2, color = "black") +
  geom_jitter(height = 0, width = 0.4, alpha = 0.2, show.legend = F) +
  geom_pointrange(data = d_por_scored_mb,
                  aes(y = mean, ymin = ci_lower, ymax = ci_upper),
                  color = "black", fatten = 2) +
  geom_text(data = data.frame(x = 0.5,
                              y = c(0*16, 0.5*16, 1*16),
                              lab = c("~ All answers 'it does not happen'",
                                      "", 
                                      # "~ All answers 'it might happen'",
                                      "~ All answers 'it definitely happens'")),
            aes(x = x, y = y, label = lab),
            color = "black", hjust = 0, nudge_y = 0.5) +
  scale_color_brewer(palette = "Dark2") +
  scale_y_continuous(breaks = seq(0, 16, 4)) +
  # ylim(0, 16) +
  labs(title = "Porosity by site",
       subtitle = "Error bars are bootstrapped 95% CIs",
       x = "Site", y = "Porosity score (average response, range: 0-16)")

por_plot_b <- ggplot(d_por_scored_mb,
                     aes(x = epi_ctry, color = epi_ctry)) +
  # geom_hline(yintercept = 0*16, lty = 2, color = "black") +
  geom_hline(yintercept = 0.5*16, lty = 2, color = "black") +
  # geom_hline(yintercept = 1*16, lty = 2, color = "black") +
  geom_pointrange(aes(y = mean, ymin = ci_lower, ymax = ci_upper),
                  fatten = 4, show.legend = F) +
  # geom_text(data = data.frame(x = 0.5,
  #                             y = 0.5 * 16, # c(0*16, 0.5*16, 1*16),
  #                             lab = "~ All answers 'maybe'"),
  #                                   # c("~ All answers 'it does not happen'",
  #                                   #   "~ All answers 'it might happen'",
  #                                   #   "~ All answers 'it definitely happens'")),
  #           aes(x = x, y = y, label = lab), 
  #           color = "black", hjust = 0, nudge_y = 0.5) +
  scale_color_brewer(palette = "Dark2") +
  scale_y_continuous(breaks = seq(0, 16, 4)) +
  labs(title = "Porosity by site (zoomed in)",
       subtitle = "Error bars are bootstrapped 95% CIs",
       x = "Site", y = "Porosity score (average response, range: 0-16)")

plot_grid(por_plot_a, por_plot_b, ncol = 2)
```

From these plots, it is clear that while there was substantial variability across individuals within each site, participants' average response also varied fairly dramatically across sites, with participants in China endorsing the fewest items, participants in the US and Thailand endorsing slightly more, and participants in Ghana and Vanuatu endorsing the most.

```{r}
r_por <- lm(score ~ epi_ctry, d_por_scored,
            contrasts = list(epi_ctry = contrasts_ctry_ctr))
```

```{r, include = T}
summary(r_por)$coefficients %>%
  data.frame() %>%
  rownames_to_column("parameter") %>%
  rename(b = Estimate, `standard error` = Std..Error, `t` = t.value,
         p = Pr...t..) %>%
  mutate_at(vars(-parameter, -p), funs(round(., 2))) %>%
  mutate(p = ifelse(p < 0.001, "<0.001", round(p, 3)),
         significant = ifelse(p < 0.05, "*", "")) %>%
  kable(align = c("l", rep("r", 5), "l"),
        caption = "Comparing porosity scores across sites [model: lm(score ~ epi_ctry, d_por_scored)]") %>%
  kable_styling() %>%
  row_spec(c(2:5), bold = T)
```

```{r}
r_por_mixed <- lmer(response ~ epi_ctry
                    + (1 | epi_subj) + (epi_ctry | question),
                    d_por,
                    contrasts = list(epi_ctry = contrasts_ctry_ctr))
```

```{r, include = T}
summary(r_por_mixed)$coefficients %>%
  data.frame() %>%
  rownames_to_column("parameter") %>%
  rename(b = Estimate, `standard error` = Std..Error, `t` = t.value,
         p = Pr...t..) %>%
  mutate_at(vars(-parameter, -p), funs(round(., 2))) %>%
  mutate(p = ifelse(p < 0.001, "<0.001", round(p, 3)),
         significant = ifelse(p < 0.05, "*", "")) %>%
  kable(align = c("l", rep("r", 5), "l"),
        caption = "Comparing porosity responses across sites [model: lmer(response ~ epi_ctry + (1 | epi_subj) + (epi_ctry | question)]") %>%
  kable_styling() %>%
  row_spec(c(2:5), bold = T)
```

I ran two kinds of statistical analyses of these results: One comparing these average scores across sites (top table), and the other taking into account variability across individual participants and across individual items in the scale (bottom table). Theoretically, these analyses should yield pretty similar results, so I would be especially confident in effects that are consistent across the two analyses and that seem obvious from the plots.

Both analyses suggest that participants in sites outside of the US generally had significantly higher Porosity scores than participants in the US (see "epi_ctrynonUS_US" rows)—but looking at the plots it is clear that this was driven by participants in Ghana and Vanuatu, and was not true, on average, among participants in Thailand or China. In line with this, both analyses suggest that participants in Ghana and Vanuatu had significantly higher Porosity scores than participants in Thailand and China—and that this difference was far greater than the difference between "the West vs. the rest" (see "epi_ctrynonUS_US" rows). Both analyses also suggest that participants in Thailand had significantly higher Porosity scores, on average, than participants in China (see "epi_ctryTH_CH" rows).

<P style="page-break-before: always">
## By item

Next, I'll examine responses to individual items on the Porosity scale, first focusing on the basic items and then turning to the follow-up questions and a few site-specific questions. For each item, participants could say "it does not happen" (scored as 0), "it might happen" (scored as 0.5), or "it definitely happens" (scored as 1).

```{r, fig.width = 6, fig.asp = 1, include = T}
d_por %>%
  filter(!grepl("a", question), !grepl("b", question), 
         !grepl("c", question)) %>%
  group_by(epi_ctry, question, question_text, order) %>%
  multi_boot_standard("response", na.rm = T) %>%
  ungroup() %>% 
  ggplot(aes(x = epi_ctry, y = mean, color = epi_ctry)) +
  facet_wrap(~ reorder(str_wrap(question_text, 50), order), ncol = 4) +
  geom_jitter(data = d_por %>% 
                filter(!grepl("a", question), !grepl("b", question), 
                       !grepl("c", question)), aes(y = response), 
              height = 0.05, alpha = 0.08, show.legend = F) +
  geom_pointrange(aes(ymin = ci_lower, ymax = ci_upper), 
                  position = position_dodge(width = 0.5), 
                  color = "black", show.legend = F) +
  scale_color_brewer(palette = "Dark2") +
  scale_y_continuous(breaks = seq(0, 1, 0.25)) +
  theme(axis.text.x = element_text(angle = 45, hjust = 1, vjust = 1)) +
  labs(title = "Porosity scale: Responses to individual items",
       subtitle = "Error bars are bootstrapped 95% CIs",
       x = "Site", 
       y = "Mean response (0 = it does not happen, 0.5 = it might happen, 1 = it definitely happens")
```

There is so much to unpack here! When I look at these items, a few things that I think about are:

- Which items tend to follow the overall pattern established by the "overall scores" presented in the previous section? (e.g., question #1, many others)
- Among items that follow the overall pattern, for which items is this pattern exaggerated? (e.g., questions #5, #12) For which items is this pattern attentuated? (e.g., quesitons #2, #3) 
- Which items do _not_ follow this overall trend? (e.g., question #16)
- Which items seem to pick out an experience that is uniquely salient/prevalent in a particular site? (e.g., questions #7, #16)

_Note that I just picked out a few examples to illustrate what I mean, but there are certainly other interesting cases that might be worth thinking about more deeply - e.g., question #15, where US participants appear more like Ghanaian & ni-Van participants than Thai or Chinese participants)._ 

Here are participants' answers to the follow-up questions for a subset of those basic items:

```{r}
por_fu_question_text <- d_por %>%
  filter(question %in% c("epi_1_01", "epi_1_04", "epi_1_06", "epi_1_07",
                         "epi_1_11", "epi_1_14")) %>%
  distinct(question, question_text, order) %>%
  mutate(question_text = as.character(question_text))
```

```{r, fig.width = 6, fig.asp = 0.8, include = T}
d_por %>%
  filter(grepl("a", question) | grepl("b", question) | grepl("c", question)) %>%
  filter(!grepl("usa", question), !grepl("gha", question), 
         !grepl("chn", question), !grepl("vut", question),
         !grepl("thl", question)) %>% 
  group_by(epi_ctry, question, question_text, order) %>%
  multi_boot_standard("response", na.rm = T) %>%
  ungroup() %>% 
  ggplot(aes(x = epi_ctry, y = mean, color = epi_ctry)) +
  facet_wrap(~ reorder(str_wrap(question_text, 30), order), ncol = 6) +
  geom_jitter(data = d_por %>% 
                filter(grepl("a", question) | grepl("b", question) |
                         grepl("c", question)) %>%
                filter(!grepl("usa", question), !grepl("gha", question), 
                       !grepl("chn", question), !grepl("vut", question),
                       !grepl("thl", question)), aes(y = response), 
              height = 0.05, alpha = 0.08, show.legend = F) +
  geom_pointrange(aes(ymin = ci_lower, ymax = ci_upper), 
                  position = position_dodge(width = 0.5), 
                  color = "black", show.legend = F) +
  scale_color_brewer(palette = "Dark2") +
  scale_y_continuous(breaks = seq(0, 2, 0.5)) +
  theme(axis.text.x = element_text(angle = 45, hjust = 1, vjust = 1)) +
  labs(title = "Porosity scale: Responses to follow-up questions",
       subtitle = paste0(por_fu_question_text$question_text %>% paste0(collapse = '\n'), "\n\nNote: these questions are NOT currently included in Porosity 'scores'\nError bars are bootstrapped 95% CIs"),
       x = "Site", 
       y = "Mean response (0 = no, 1 = a little, 2 = a lot)")
```

And here are participants' answers to a few site-specific questions:

```{r}
por_sitespec_question_text <- d_por %>%
  filter(grepl("usa", question) | grepl("gha", question) |
         grepl("chn", question)| grepl("vut", question) |
         grepl("thl", question)) %>%
  distinct(question, question_text, order) %>%
  mutate(question_text = as.character(question_text))
```

```{r, fig.width = 6, fig.asp = 0.4, include = T}
d_por %>%
  filter(grepl("usa", question) | grepl("gha", question) |
         grepl("chn", question)| grepl("vut", question) |
         grepl("thl", question)) %>% 
  group_by(epi_ctry, question, question_text, order) %>%
  multi_boot_standard("response", na.rm = T) %>%
  ungroup() %>% 
  ggplot(aes(x = epi_ctry, y = mean, color = epi_ctry)) +
  facet_wrap(~ reorder(str_wrap(question_text, 40), order), 
             ncol = 4, scales = "free_x") +
  geom_jitter(data = d_por %>% 
                filter(grepl("usa", question) | grepl("gha", question) |
                         grepl("chn", question)| grepl("vut", question) |
                         grepl("thl", question)), aes(y = response), 
              height = 0.05, alpha = 0.08, show.legend = F) +
  geom_pointrange(aes(ymin = ci_lower, ymax = ci_upper), 
                  position = position_dodge(width = 0.5), 
                  color = "black", show.legend = F) +
  scale_color_brewer(palette = "Dark2") +
  scale_y_continuous(breaks = seq(0, 1, 0.25)) +
  theme(axis.text.x = element_text(angle = 45, hjust = 1, vjust = 1)) +
  labs(title = "Porosity scale: Responses to site-specific questions",
       subtitle = "Note: these questions are NOT currently included in Porosity 'scores'\nError bars are bootstrapped 95% CIs",
       x = "Site", 
       y = "Mean response (0 = no, 0.5 = maybe, 1 = yes)")
```


<P style="page-break-before: always">
# Prayer (spiritual experience Question #1)

For Spiritual Epidemiology, the "spiritual experience" portion of the epidemiology began with two questions intended to gauge participants' prayer practice. Here are participants' responses to these two questions:

```{r, fig.width = 6, fig.asp = 0.35, include = T}
d_prayer %>%
  group_by(epi_ctry, question, question_text, order) %>%
  multi_boot_standard("response", na.rm = T) %>%
  ungroup() %>% 
  ggplot(aes(x = epi_ctry, y = mean, color = epi_ctry)) +
  facet_wrap(~ reorder(str_wrap(question_text, 90), order), ncol = 2,
             scales = "free") +
  geom_jitter(data = d_prayer, aes(y = response), 
              height = 0.05, alpha = 0.08, show.legend = F) +
  geom_pointrange(aes(ymin = ci_lower, ymax = ci_upper), 
                  position = position_dodge(width = 0.5), 
                  color = "black", show.legend = F) +
  scale_color_brewer(palette = "Dark2") +
  scale_y_continuous(breaks = seq(0, 4, 0.5)) +
  theme(axis.text.x = element_text(angle = 45, hjust = 1, vjust = 1)) +
  labs(title = "Prayer",
       subtitle = "Error bars are bootstrapped 95% CIs\nFor question #1, 0 = no, 1 = yes; for question #1a, 1 = 0-15min, 2 = 15-30min, 3 = 30-60min, 4 = >60min",
       x = "Site", 
       y = "Mean response (scales varied by question)")
```


<P style="page-break-before: always">
# All spiritual experiences (Questions #2-23)

For Spiritual Epidemiology, the Spiritual Experiences scale consisted of 22 basic items (34 basic items in Thailand), and follow-up questions to a subset of these items. For each of the basic items, participants could respond by saying "no" (scored as 0), "maybe" (scored as 0.5; this might have only been available in some sites?), or "yes" (scored as 1).

_Note: In addition to these 22 items, there were two items included as part of this section on "spiritual experiences" that were intended to gauge participants' prayer practice - see [Prayer (spiritual experience Question #1)], above._

## Overall scores

First, I'll examine overall "scores" on this scale, taking into account only the basic items (not the follow-up questions). 

In Thailand, there were an additional 12 quesitons (about experiences of additional "beings") that; I have treated this discrepancy across sites in two different ways below: (1) Consdering all beings and using proportions, rather than sums, as "scores" (equivalent to asking, for each particiant, what proportion of the items they were exposed to did they endorse?); and (2) Considering only the first 5 beings asked about in each site, such that all participants were asked the same number of questions.

## Considering all "beings"

Using the first approach (considering all "beings," with 12 more beings in Thailand than in any other site), scores could range from 0 (equivalent to saying "no" for all 22-34 items) to 1 (equivalent to saying "yes" for all 22-34 items).

```{r}
d_spex_base_q2to23_scored_propall_mb <- d_spex_base_q2to23_scored_propall %>%
  group_by(epi_ctry) %>%
  multi_boot_standard("score") %>%
  ungroup()
```

```{r, fig.width = 4, fig.asp = 0.6, include = T}
spex_q2to23_plot_a <- ggplot(d_spex_base_q2to23_scored_propall,
                            aes(x = epi_ctry, y = score, 
                                color = epi_ctry)) +
  geom_hline(yintercept = 0*1, lty = 2, color = "black") +
  geom_hline(yintercept = 0.5*1, lty = 2, color = "black") +
  geom_hline(yintercept = 1*1, lty = 2, color = "black") +
  geom_jitter(height = 0, width = 0.4, alpha = 0.2, show.legend = F) +
  geom_pointrange(data = d_spex_base_q2to23_scored_propall_mb,
                  aes(y = mean, ymin = ci_lower, ymax = ci_upper),
                  fatten = 2, color = "black", show.legend = F) +
  geom_text(data = data.frame(x = 0.5,
                              y = c(0*1, 0.5*1, 1*1),
                              lab = c("~ All answers 'no'",
                                      "",
                                      # "~ All answers 'maybe'",
                                      "~ All answers 'yes'")),
            aes(x = x, y = y, label = lab),
            color = "black", hjust = 0, nudge_y = 0.05) +
  scale_color_brewer(palette = "Dark2") +
  scale_y_continuous(breaks = seq(0, 1, 0.1)) +
  labs(title = "Spiritual experiences (Questions #2-23)",
       subtitle = "Includes all beings for Thailand\nError bars are bootstrapped 95% CIs",
       x = "Site", y = "Proportion score (range: 0-1)")

spex_q2to23_plot_b <- ggplot(d_spex_base_q2to23_scored_propall_mb,
                            aes(x = epi_ctry, y = mean, color = epi_ctry)) +
  geom_pointrange(aes(ymin = ci_lower, ymax = ci_upper),
                  fatten = 4, show.legend = F) +
  scale_color_brewer(palette = "Dark2") +
  scale_y_continuous(breaks = seq(0, 1, 0.1)) +
  labs(title = "Spiritual experiences (zoomed in)",
       subtitle = "Includes all beings for Thailand\nError bars are bootstrapped 95% CIs",
       x = "Site", y = "Proportion score (range: 0-1)")

plot_grid(spex_q2to23_plot_a, spex_q2to23_plot_b, ncol = 2)
```

From these plots, it is clear that while there was substantial variability across individuals within each site, participants’ average response also varied fairly dramatically across sites, with participants in China endorsing the fewest items, participants in the US and Thailand endorsing slightly more, and participants in Ghana and Vanuatu endorsing the most. This is the same pattern we observed for [Porosity] scores, above.

```{r}
r_q2to23_scored_propall <- lm(score ~ epi_ctry, 
                              d_spex_base_q2to23_scored_propall,
                              contrasts = list(epi_ctry = contrasts_ctry_ctr))
```

```{r, include = T}
summary(r_q2to23_scored_propall)$coefficients %>%
  data.frame() %>%
  rownames_to_column("parameter") %>%
  rename(b = Estimate, `standard error` = Std..Error, `t` = t.value,
         p = Pr...t..) %>%
  mutate_at(vars(-parameter, -p), funs(round(., 2))) %>%
  mutate(p = ifelse(p < 0.001, "<0.001", round(p, 3)),
         significant = ifelse(p < 0.05, "*", "")) %>%
  kable(align = c("l", rep("r", 5), "l"),
        caption = "Comparing spiritual experience scores across sites [model: lm(score ~ epi_ctry, d_spex_base_q2to23_scored_propall)]") %>%
  kable_styling() %>%
  row_spec(c(2:5), bold = T)
```

```{r}
r_q2to23_propall_mixed <- lmer(response ~ epi_ctry 
                               + (1 | epi_subj) + (epi_ctry | question),
                               d_spex_base_q2to23,
                               contrasts = list(epi_ctry = contrasts_ctry_ctr))
```

```{r, include = T}
summary(r_q2to23_propall_mixed)$coefficients %>%
  data.frame() %>%
  rownames_to_column("parameter") %>%
  rename(b = Estimate, `standard error` = Std..Error, `t` = t.value,
         p = Pr...t..) %>%
  mutate_at(vars(-parameter, -p), funs(round(., 2))) %>%
  mutate(p = ifelse(p < 0.001, "<0.001", round(p, 3)),
         significant = ifelse(p < 0.05, "*", "")) %>%
  kable(align = c("l", rep("r", 5), "l"),
        caption = "Comparing spiritual experience responses across sites [model: lmer(response ~ epi_ctry + (1 | epi_subj) + (epi_ctry | question), d_spex_base_q2to23)]") %>%
  kable_styling() %>%
  row_spec(c(2:5), bold = T)
```

Again, I ran two kinds of statistical analyses of these results: One comparing these scores across sites (top table), and the other taking into account variability across individual participants and across individual items in the scale (bottom table). Theoretically, these analyses should yield pretty similar results, so I would be especially confident in effects that are consistent across the two analyses and that seem obvious from the plots.

Both analyses suggest that participants in sites outside of the US generally had significantly higher Porosity scores than participants in Ghana and Vanuatu had significantly higher Porosity scores than participants in Thailand and China (see “epi_ctrynonUS_US” rows), and that participants in Thailand had significantly higher Porosity scores, on average, than participants in China (see “epi_ctryTH_CH” rows).

<P style="page-break-before: always">
## Considering first five "beings" only

Using the second approach (considering only the first five "beings" in each site), scores could range from 0 (equivalent to saying "no" for all 22 items) to 22 (equivalent to saying "yes" for all 22 items).

```{r}
d_spex_base_q2to23_scored_first5_mb <- d_spex_base_q2to23_scored_first5 %>%
  group_by(epi_ctry) %>%
  multi_boot_standard("score") %>%
  ungroup()
```

```{r, fig.width = 4, fig.asp = 0.6, include = T}
spex_q2to23_plot_c <- ggplot(d_spex_base_q2to23_scored_first5,
                            aes(x = epi_ctry, y = score, 
                                color = epi_ctry)) +
  geom_hline(yintercept = 0*22, lty = 2, color = "black") +
  geom_hline(yintercept = 0.5*22, lty = 2, color = "black") +
  geom_hline(yintercept = 1*22, lty = 2, color = "black") +
  geom_jitter(height = 0, width = 0.4, alpha = 0.2, show.legend = F) +
  geom_pointrange(data = d_spex_base_q2to23_scored_first5_mb,
                  aes(y = mean, ymin = ci_lower, ymax = ci_upper),
                  fatten = 2, color = "black", show.legend = F) +
  geom_text(data = data.frame(x = 0.5,
                              y = c(0*22, 0.5*22, 1*22),
                              lab = c("~ All answers 'no'",
                                      "",
                                      # "~ All answers 'maybe'",
                                      "~ All answers 'yes'")),
            aes(x = x, y = y, label = lab),
            color = "black", hjust = 0, nudge_y = 1) +
  scale_color_brewer(palette = "Dark2") +
  scale_y_continuous(breaks = seq(0, 22, 2)) +
  labs(title = "Spiritual experiences (Questions #2-23)",
       subtitle = "Includes first five beings for all sites\nError bars are bootstrapped 95% CIs",
       x = "Site", y = "Sum score (range: 0-22)")

spex_q2to23_plot_d <- ggplot(d_spex_base_q2to23_scored_first5_mb,
                            aes(x = epi_ctry, y = mean, color = epi_ctry)) +
  geom_pointrange(aes(ymin = ci_lower, ymax = ci_upper),
                  fatten = 4, show.legend = F) +
  scale_color_brewer(palette = "Dark2") +
  scale_y_continuous(breaks = seq(0, 22, 2)) +
  labs(title = "Spiritual experiences (zoomed in)",
       subtitle = "Includes first five beings for all sites\nError bars are bootstrapped 95% CIs",
       x = "Site", y = "Sum score (range: 0-22)")

plot_grid(spex_q2to23_plot_c, spex_q2to23_plot_d, ncol = 2)
```

These plots look very similar to the plots considering all beings (which I find reassuring).

```{r}
r_q2to23_scored_first5 <- lm(score ~ epi_ctry, 
                             d_spex_base_q2to23_scored_first5,
                             contrasts = list(epi_ctry = contrasts_ctry_ctr))
```

```{r, include = T}
summary(r_q2to23_scored_first5)$coefficients %>%
  data.frame() %>%
  rownames_to_column("parameter") %>%
  rename(b = Estimate, `standard error` = Std..Error, `t` = t.value,
         p = Pr...t..) %>%
  mutate_at(vars(-parameter, -p), funs(round(., 2))) %>%
  mutate(p = ifelse(p < 0.001, "<0.001", round(p, 3)),
         significant = ifelse(p < 0.05, "*", "")) %>%
  kable(align = c("l", rep("r", 5), "l"),
        caption = "Comparing spiritual experience scores across sites [model: lm(score ~ epi_ctry, d_spex_base_q2to23_scored_first5)]") %>%
  kable_styling() %>%
  row_spec(c(2:5), bold = T)
```

```{r}
r_q2to23_first5_mixed <- lmer(response ~ epi_ctry 
                              + (1 | epi_subj) + (epi_ctry | question),
                              d_spex_base_q2to23 %>%
                                filter(!question %in% 
                                         c("epi_2_thl12e", "epi_2_thl12f", 
                                           "epi_2_thl12g", "epi_2_thl12h", 
                                           "epi_2_thl12i", "epi_2_thl12j",
                                           "epi_2_thl12k")),
                              contrasts = list(epi_ctry = contrasts_ctry_ctr))
```

```{r, include = F}
summary(r_q2to23_first5_mixed)$coefficients %>%
  data.frame() %>%
  rownames_to_column("parameter") %>%
  rename(b = Estimate, `standard error` = Std..Error, `t` = t.value,
         p = Pr...t..) %>%
  mutate_at(vars(-parameter, -p), funs(round(., 2))) %>%
  mutate(p = ifelse(p < 0.001, "<0.001", round(p, 3)),
         significant = ifelse(p < 0.05, "*", "")) %>%
  kable(align = c("l", rep("r", 5), "l"),
        caption = "Comparing spiritual experience responses across sites [model: lmer(response ~ epi_ctry + (1 | epi_subj) + (epi_ctry | question), d_spex_base_q2to23 %>% filter(...))]") %>%
  kable_styling() %>%
  row_spec(c(2:5), bold = T)
```

This pattern of results are identical to the pattern of results considering all beings (which, again, I find reassuring).


<P style="page-break-before: always">
**In the following four sections ([Spiritual experiences: Universal questions, set 1 (Questions #2-10)], [Spiritual experiences: Beings questions (Questions #11-15 + more for Thailand)], [Spiritual experiences: Universal questions, set 2 (Questions #16-21)], and [Spiritual experiences: Universal questions, set 3 (Questions #22-23)]), I look at scores for sub-sections of the Spiritual Experience scale, and at responses to individual items in this scale, including follow-up items.** I do not provide text commentary on these additional plots and analyses at this time, but they all follow the same logic as the plots and analyses that I have annotated above.


# Spiritual experiences: Universal questions, set 1 (Questions #2-10)

## Overall scores

```{r}
d_spex_base_q2to10_scored_mb <- d_spex_base_q2to10_scored %>%
  group_by(epi_ctry) %>%
  multi_boot_standard("score") %>%
  ungroup()
```

```{r, fig.width = 4, fig.asp = 0.6, include = T}
spex_2to10_plot_a <- ggplot(d_spex_base_q2to10_scored,
                            aes(x = epi_ctry, y = score, color = epi_ctry)) +
  geom_hline(yintercept = 0*9, lty = 2, color = "black") +
  geom_hline(yintercept = 0.5*9, lty = 2, color = "black") +
  geom_hline(yintercept = 1*9, lty = 2, color = "black") +
  geom_jitter(height = 0.1, width = 0.4, alpha = 0.2, show.legend = F) +
  geom_pointrange(data = d_spex_base_q2to10_scored_mb,
                  aes(y = mean, ymin = ci_lower, ymax = ci_upper),
                  fatten = 2, color = "black", show.legend = F) +
  geom_text(data = data.frame(x = 0.5,
                              y = c(0*9, 0.5*9, 1*9),
                              lab = c("~ All answers 'no'",
                                      "",
                                      # "~ All answers 'maybe'",
                                      "~ All answers 'yes'")),
            aes(x = x, y = y, label = lab),
            color = "black", hjust = 0, nudge_y = 0.5) +
  scale_color_brewer(palette = "Dark2") +
  scale_y_continuous(breaks = seq(0, 9, 1)) +
  labs(title = "Spiritual experiences (Questions #2-10)",
       subtitle = "Error bars are bootstrapped 95% CIs",
       x = "Site", y = "Score (range: 0-9)")

spex_2to10_plot_b <- ggplot(d_spex_base_q2to10_scored_mb,
                            aes(x = epi_ctry, y = mean, color = epi_ctry)) +
  geom_pointrange(aes(ymin = ci_lower, ymax = ci_upper),
                  fatten = 4, show.legend = F) +
  scale_color_brewer(palette = "Dark2") +
  scale_y_continuous(breaks = seq(0, 9, 1)) +
  labs(title = "Spiritual experiences (zoomed in)",
       subtitle = "Error bars are bootstrapped 95% CIs",
       x = "Site", y = "Score (range: 0-9)")

plot_grid(spex_2to10_plot_a, spex_2to10_plot_b, ncol = 2)
```

<P style="page-break-before: always">
## By item

```{r, fig.width = 6, fig.asp = 1, include = T}
d_spex_base_q2to10 %>%
  group_by(epi_ctry, question, question_text, order) %>%
  multi_boot_standard("response", na.rm = T) %>%
  ungroup() %>% 
  ggplot(aes(x = epi_ctry, y = mean, color = epi_ctry)) +
  facet_wrap(~ str_wrap(question_text, 50), ncol = 3) +
  facet_wrap(~ reorder(str_wrap(question_text, 60), order), ncol = 3) +
  geom_jitter(data = d_spex_base_q2to10, aes(y = response), 
              height = 0.05, alpha = 0.08, show.legend = F) +
  geom_pointrange(aes(ymin = ci_lower, ymax = ci_upper), 
                  position = position_dodge(width = 0.5), 
                  color = "black", show.legend = F) +
  scale_color_brewer(palette = "Dark2") +
  scale_y_continuous(breaks = seq(0, 1, 0.25)) +
  theme(axis.text.x = element_text(angle = 45, hjust = 1, vjust = 1)) +
  labs(title = "Spiritual experiences #2-10: Responses to individual items",
       subtitle = "Error bars are bootstrapped 95% CIs",
       x = "Site", 
       y = "Mean response, i.e., proportion responding 'yes' (0 = no, 1 = yes)")
```


<P style="page-break-before: always">
# Spiritual experiences: Beings questions (Questions #11-15 + more for Thailand)

## Overall scores

### Considering all "beings" (more for Thailand)

```{r}
d_spex_base_q11to15_scored_propall_mb <- d_spex_base_q11to15_scored %>%
  group_by(epi_ctry) %>%
  multi_boot_standard("score_propall", na.rm = T) %>%
  ungroup()
```

```{r, fig.width = 4, fig.asp = 0.6, include = T}
spex_11to15_plot_a <- ggplot(d_spex_base_q11to15_scored,
                            aes(x = epi_ctry, y = score_propall, 
                                color = epi_ctry)) +
  geom_hline(yintercept = 0*1, lty = 2, color = "black") +
  geom_hline(yintercept = 0.5*1, lty = 2, color = "black") +
  geom_hline(yintercept = 1*1, lty = 2, color = "black") +
  geom_jitter(height = 0.02, width = 0.4, alpha = 0.2, show.legend = F) +
  geom_pointrange(data = d_spex_base_q11to15_scored_propall_mb,
                  aes(y = mean, ymin = ci_lower, ymax = ci_upper),
                  fatten = 2, color = "black", show.legend = F) +
  geom_text(data = data.frame(x = 0.5,
                              y = c(0*1, 0.5*1, 1*1),
                              lab = c("~ All answers 'no'",
                                      "",
                                      # "~ All answers 'maybe'",
                                      "~ All answers 'yes'")),
            aes(x = x, y = y, label = lab),
            color = "black", hjust = 0, nudge_y = 0.05) +
  scale_color_brewer(palette = "Dark2") +
  scale_y_continuous(breaks = seq(0, 1, 0.2)) +
  labs(title = "Spiritual experiences (Questions #11-15+)",
       subtitle = "Includes all beings for Thailand\nError bars are bootstrapped 95% CIs",
       x = "Site", y = "Proportion score (range: 0-1)")

spex_11to15_plot_b <- ggplot(d_spex_base_q11to15_scored_propall_mb,
                            aes(x = epi_ctry, y = mean, color = epi_ctry)) +
  geom_pointrange(aes(ymin = ci_lower, ymax = ci_upper),
                  fatten = 4, show.legend = F) +
  scale_color_brewer(palette = "Dark2") +
  scale_y_continuous(breaks = seq(0, 1, 0.2)) +
  labs(title = "Spiritual experiences (zoomed in)",
       subtitle = "Includes all beings for Thailand\nError bars are bootstrapped 95% CIs",
       x = "Site", y = "Proportion score (range: 0-1)")

plot_grid(spex_11to15_plot_a, spex_11to15_plot_b, ncol = 2)
```

<P style="page-break-before: always">
### Considering first five "beings" only

```{r}
d_spex_base_q11to15_scored_first5_mb <- d_spex_base_q11to15_scored %>%
  group_by(epi_ctry) %>%
  multi_boot_standard("score_first5", na.rm = T) %>%
  ungroup()
```

```{r, fig.width = 4, fig.asp = 0.6, include = T}
spex_11to15_plot_c <- ggplot(d_spex_base_q11to15_scored,
                            aes(x = epi_ctry, y = score_first5, 
                                color = epi_ctry)) +
  geom_hline(yintercept = 0*5, lty = 2, color = "black") +
  geom_hline(yintercept = 0.5*5, lty = 2, color = "black") +
  geom_hline(yintercept = 1*5, lty = 2, color = "black") +
  geom_jitter(height = 0.1, width = 0.4, alpha = 0.2, show.legend = F) +
  geom_pointrange(data = d_spex_base_q11to15_scored_first5_mb,
                  aes(y = mean, ymin = ci_lower, ymax = ci_upper),
                  fatten = 2, color = "black", show.legend = F) +
  geom_text(data = data.frame(x = 0.5,
                              y = c(0*5, 0.5*5, 1*5),
                              lab = c("~ All answers 'no'",
                                      "",
                                      # "~ All answers 'maybe'",
                                      "~ All answers 'yes'")),
            aes(x = x, y = y, label = lab),
            color = "black", hjust = 0, nudge_y = 0.25) +
  scale_color_brewer(palette = "Dark2") +
  scale_y_continuous(breaks = seq(0, 5, 1)) +
  labs(title = "Spiritual experiences (Questions #11-15+)",
       subtitle = "Includes first five beings for all sites\nError bars are bootstrapped 95% CIs",
       x = "Site", y = "Sum score (range: 0-5)")

spex_11to15_plot_d <- ggplot(d_spex_base_q11to15_scored_first5_mb,
                            aes(x = epi_ctry, y = mean, color = epi_ctry)) +
  geom_pointrange(aes(ymin = ci_lower, ymax = ci_upper),
                  fatten = 4, show.legend = F) +
  scale_color_brewer(palette = "Dark2") +
  scale_y_continuous(breaks = seq(0, 5, 1)) +
  labs(title = "Spiritual experiences (zoomed in)",
       subtitle = "Includes first five beings for all sites\nError bars are bootstrapped 95% CIs",
       x = "Site", y = "Sum score (range: 0-5)")

plot_grid(spex_11to15_plot_c, spex_11to15_plot_d, ncol = 2)
```

<P style="page-break-before: always">
## By item

```{r}
spex_11to15_plot_us <- d_spex_base_q11to15 %>%
  filter(epi_ctry == "US", grepl("usa", question)) %>%
  group_by(epi_ctry, question, question_text, order) %>%
  multi_boot_standard("response", na.rm = T) %>%
  ungroup() %>% 
  ggplot(aes(x = epi_ctry, y = mean)) +
  facet_wrap(~ reorder(str_wrap(question_text, 40), order), ncol = 5) +
  geom_jitter(data = d_spex_base_q11to15 %>% 
                filter(epi_ctry == "US", grepl("usa", question)), 
              aes(y = response), 
              height = 0.05, alpha = 0.08, color = "#1b9e77", show.legend = F) +
  geom_pointrange(aes(ymin = ci_lower, ymax = ci_upper), 
                  position = position_dodge(width = 0.5), 
                  color = "black", show.legend = F) +
  scale_color_brewer(palette = "Dark2") +
  scale_y_continuous(breaks = seq(0, 1, 0.25)) +
  labs(title = "US Spiritual experiences #11-15: Responses to individual items",
       subtitle = "Error bars are bootstrapped 95% CIs",
       x = "Site", 
       y = "Mean response (0 = no, 1 = yes)")
```

```{r}
spex_11to15_plot_gh <- d_spex_base_q11to15 %>%
  filter(epi_ctry == "Ghana", grepl("gha", question)) %>%
  group_by(epi_ctry, question, question_text, order) %>%
  multi_boot_standard("response", na.rm = T) %>%
  ungroup() %>% 
  ggplot(aes(x = epi_ctry, y = mean)) +
  facet_wrap(~ reorder(str_wrap(question_text, 40), order), ncol = 5) +
  geom_jitter(data = d_spex_base_q11to15 %>% 
                filter(epi_ctry == "Ghana", grepl("gha", question)), 
              aes(y = response), 
              height = 0.05, alpha = 0.08, color = "#d95f02", show.legend = F) +
  geom_pointrange(aes(ymin = ci_lower, ymax = ci_upper), 
                  position = position_dodge(width = 0.5), 
                  color = "black", show.legend = F) +
  scale_color_brewer(palette = "Dark2") +
  scale_y_continuous(breaks = seq(0, 1, 0.25)) +
  labs(title = "GHANA Spiritual experiences #11-15: Responses to individual items",
       subtitle = "Error bars are bootstrapped 95% CIs",
       x = "Site", 
       y = "Mean response (0 = no, 1 = yes)")
```

```{r}
spex_11to15_plot_th <- d_spex_base_q11to15 %>%
  filter(epi_ctry == "Thailand", grepl("thl", question)) %>%
  group_by(epi_ctry, question, question_text, order) %>%
  multi_boot_standard("response", na.rm = T) %>%
  ungroup() %>% 
  ggplot(aes(x = epi_ctry, y = mean)) +
  facet_wrap(~ reorder(str_wrap(question_text, 40), order), ncol = 5) +
  geom_jitter(data = d_spex_base_q11to15 %>% 
                filter(epi_ctry == "Thailand", grepl("thl", question)), 
              aes(y = response), 
              height = 0.05, alpha = 0.08, color = "#7570b3", show.legend = F) +
  geom_pointrange(aes(ymin = ci_lower, ymax = ci_upper), 
                  position = position_dodge(width = 0.5), 
                  color = "black", show.legend = F) +
  scale_color_brewer(palette = "Dark2") +
  scale_y_continuous(breaks = seq(0, 1, 0.25)) +
  labs(title = "THAILAND Spiritual experiences #11-15: Responses to individual items",
       subtitle = "Error bars are bootstrapped 95% CIs",
       x = "Site", 
       y = "Mean response (0 = no, 1 = yes)")
```

```{r}
spex_11to15_plot_ch <- d_spex_base_q11to15 %>%
  filter(epi_ctry == "China", grepl("chn", question)) %>%
  group_by(epi_ctry, question, question_text, order) %>%
  multi_boot_standard("response", na.rm = T) %>%
  ungroup() %>% 
  ggplot(aes(x = epi_ctry, y = mean)) +
  facet_wrap(~ reorder(str_wrap(question_text, 40), order), ncol = 5) +
  geom_jitter(data = d_spex_base_q11to15 %>% 
                filter(epi_ctry == "China", grepl("chn", question)), 
              aes(y = response), 
              height = 0.05, alpha = 0.08, color = "#e7298a", show.legend = F) +
  geom_pointrange(aes(ymin = ci_lower, ymax = ci_upper), 
                  position = position_dodge(width = 0.5), 
                  color = "black", show.legend = F) +
  scale_color_brewer(palette = "Dark2") +
  scale_y_continuous(breaks = seq(0, 1, 0.25)) +
  labs(title = "CHINA Spiritual experiences #11-15: Responses to individual items",
       subtitle = "Error bars are bootstrapped 95% CIs",
       x = "Site", 
       y = "Mean response (0 = no, 1 = yes)")
```

```{r}
spex_11to15_plot_vt <- d_spex_base_q11to15 %>%
  filter(epi_ctry == "Vanuatu", grepl("vut", question)) %>%
  group_by(epi_ctry, question, question_text, order) %>%
  multi_boot_standard("response", na.rm = T) %>%
  ungroup() %>% 
  ggplot(aes(x = epi_ctry, y = mean)) +
  facet_wrap(~ reorder(str_wrap(question_text, 40), order), ncol = 5) +
  geom_jitter(data = d_spex_base_q11to15 %>% 
                filter(epi_ctry == "Vanuatu", grepl("vut", question)), 
              aes(y = response), 
              height = 0.05, alpha = 0.08, color = "#66a61e", show.legend = F) +
  geom_pointrange(aes(ymin = ci_lower, ymax = ci_upper), 
                  position = position_dodge(width = 0.5), 
                  color = "black", show.legend = F) +
  scale_color_brewer(palette = "Dark2") +
  scale_y_continuous(breaks = seq(0, 1, 0.25)) +
  labs(title = "VANUATU Spiritual experiences #11-15: Responses to individual items",
       subtitle = "Error bars are bootstrapped 95% CIs",
       x = "Site", 
       y = "Mean response (0 = no, 1 = yes)")
```

```{r, fig.width = 6, fig.asp = 1.7, include = F}
# plot_grid(spex_11to15_plot_us, spex_11to15_plot_gh, spex_11to15_plot_th,
#           spex_11to15_plot_ch, spex_11to15_plot_vt, ncol = 1,
#           rel_heights = c(1, 1, 2, 1, 1))
```

```{r, fig.width = 4, fig.asp = 2, include = T}
d_spex_base_q11to15 %>%
  group_by(epi_ctry, question, question_text, order) %>%
  multi_boot_standard("response", na.rm = T) %>%
  ungroup() %>% 
  filter(!is.na(mean), mean != "NaN") %>%
  ggplot(aes(x = reorder(str_wrap(question_text, 60), desc(order)), 
             y = mean, color = epi_ctry)) +
  facet_grid(epi_ctry ~ ., scales = "free", space = "free") +
  geom_jitter(data = d_spex_base_q11to15 %>% filter(!is.na(response)),
              aes(y = response),
              height = 0.05, alpha = 0.08, show.legend = F) +
  geom_pointrange(aes(ymin = ci_lower, ymax = ci_upper),
                  position = position_dodge(width = 0.5),
                  color = "black", show.legend = F) +
  scale_color_brewer(palette = "Dark2") +
  scale_y_continuous(breaks = seq(0, 1, 0.25)) +
  labs(title = "Spiritual experiences #11-15:\nResponses to individual items",
       subtitle = "Error bars are bootstrapped 95% CIs",
       x = "Question", 
       y = "Mean response, i.e., proportion responding 'yes' (0 = no, 1 = yes)") +
  coord_flip()
```


<P style="page-break-before: always">
# Spiritual experiences: Universal questions, set 2 (Questions #16-21)

## Overall scores

```{r}
d_spex_base_q16to21_scored_mb <- d_spex_base_q16to21_scored %>%
  group_by(epi_ctry) %>%
  multi_boot_standard("score") %>%
  ungroup()
```

```{r, fig.width = 4, fig.asp = 0.6, include = T}
spex_q16to21_plot_a <- ggplot(d_spex_base_q16to21_scored,
                            aes(x = epi_ctry, y = score, color = epi_ctry)) +
  geom_hline(yintercept = 0*6, lty = 2, color = "black") +
  geom_hline(yintercept = 0.5*6, lty = 2, color = "black") +
  geom_hline(yintercept = 1*6, lty = 2, color = "black") +
  geom_jitter(height = 0.2, width = 0.4, alpha = 0.2, show.legend = F) +
  geom_pointrange(data = d_spex_base_q16to21_scored_mb,
                  aes(y = mean, ymin = ci_lower, ymax = ci_upper),
                  fatten = 2, color = "black", show.legend = F) +
  geom_text(data = data.frame(x = 0.5,
                              y = c(0*6, 0.5*6, 1*6),
                              lab = c("~ All answers 'no'",
                                      "",
                                      # "~ All answers 'maybe'",
                                      "~ All answers 'yes'")),
            aes(x = x, y = y, label = lab),
            color = "black", hjust = 0, nudge_y = 0.25) +
  scale_color_brewer(palette = "Dark2") +
  scale_y_continuous(breaks = seq(0, 6, 1)) +
  labs(title = "Spiritual experiences (Questions #16-21)",
       subtitle = "Error bars are bootstrapped 95% CIs",
       x = "Site", y = "Score (range: 0-6)")

spex_q16to21_plot_b <- ggplot(d_spex_base_q16to21_scored_mb,
                            aes(x = epi_ctry, y = mean, color = epi_ctry)) +
  geom_pointrange(aes(ymin = ci_lower, ymax = ci_upper),
                  fatten = 4, show.legend = F) +
  scale_color_brewer(palette = "Dark2") +
  scale_y_continuous(breaks = seq(0, 6, 1)) +
  labs(title = "Spiritual experiences (zoomed in)",
       subtitle = "Error bars are bootstrapped 95% CIs",
       x = "Site", y = "Score (range: 0-6)")

plot_grid(spex_q16to21_plot_a, spex_q16to21_plot_b, ncol = 2)
```

<P style="page-break-before: always">
## By item

```{r, fig.width = 6, fig.asp = 0.7, include = T}
d_spex_base_q16to21 %>%
  group_by(epi_ctry, question, question_text, order) %>%
  multi_boot_standard("response", na.rm = T) %>%
  ungroup() %>% 
  ggplot(aes(x = epi_ctry, y = mean, color = epi_ctry)) +
  facet_wrap(~ str_wrap(question_text, 50), ncol = 3) +
  facet_wrap(~ reorder(str_wrap(question_text, 61), order), ncol = 3) +
  geom_jitter(data = d_spex_base_q16to21, aes(y = response), 
              height = 0.05, alpha = 0.08, show.legend = F) +
  geom_pointrange(aes(ymin = ci_lower, ymax = ci_upper), 
                  position = position_dodge(width = 0.5), 
                  color = "black", show.legend = F) +
  scale_color_brewer(palette = "Dark2") +
  scale_y_continuous(breaks = seq(0, 1, 0.25)) +
  theme(axis.text.x = element_text(angle = 45, hjust = 1, vjust = 1)) +
  labs(title = "Spiritual experiences #16-21: Responses to individual items",
       subtitle = "Error bars are bootstrapped 95% CIs",
       x = "Site", 
       y = "Mean response, i.e., proportion responding 'yes' (0 = no, 1 = yes)")
```


<P style="page-break-before: always">
# Spiritual experiences: Universal questions, set 3 (Questions #22-23)

## Overall scores

```{r}
d_spex_base_q22to23_scored_mb <- d_spex_base_q22to23_scored %>%
  group_by(epi_ctry) %>%
  multi_boot_standard("score") %>%
  ungroup()
```

```{r, fig.width = 4, fig.asp = 0.6, include = T}
spex_q22to23_plot_a <- ggplot(d_spex_base_q22to23_scored,
                            aes(x = epi_ctry, y = score, color = epi_ctry)) +
  geom_hline(yintercept = 0*2, lty = 2, color = "black") +
  geom_hline(yintercept = 0.5*2, lty = 2, color = "black") +
  geom_hline(yintercept = 1*2, lty = 2, color = "black") +
  geom_jitter(height = 0.2, width = 0.4, alpha = 0.2, show.legend = F) +
  geom_pointrange(data = d_spex_base_q22to23_scored_mb,
                  aes(y = mean, ymin = ci_lower, ymax = ci_upper),
                  fatten = 2, color = "black", show.legend = F) +
  geom_text(data = data.frame(x = 0.5,
                              y = c(0*2, 0.5*2, 1*2),
                              lab = c("~ All answers 'no'",
                                      "",
                                      # "~ All answers 'maybe'",
                                      "~ All answers 'yes'")),
            aes(x = x, y = y, label = lab),
            color = "black", hjust = 0, nudge_y = 0.1) +
  scale_color_brewer(palette = "Dark2") +
  scale_y_continuous(breaks = seq(0, 2, 1)) +
  labs(title = "Spiritual experiences (Questions #22-23)",
       subtitle = "Error bars are bootstrapped 95% CIs",
       x = "Site", y = "Score (range: 0-2)")

spex_q22to23_plot_b <- ggplot(d_spex_base_q22to23_scored_mb,
                            aes(x = epi_ctry, y = mean, color = epi_ctry)) +
  geom_pointrange(aes(ymin = ci_lower, ymax = ci_upper),
                  fatten = 4, show.legend = F) +
  scale_color_brewer(palette = "Dark2") +
  scale_y_continuous(breaks = seq(0, 2, 1)) +
  labs(title = "Spiritual experiences (zoomed in)",
       subtitle = "Error bars are bootstrapped 95% CIs",
       x = "Site", y = "Score (range: 0-2)")

plot_grid(spex_q22to23_plot_a, spex_q22to23_plot_b, ncol = 2)
```

<P style="page-break-before: always">
## By item

```{r, fig.width = 6, fig.asp = 0.35, include = T}
d_spex_base_q22to23 %>%
  group_by(epi_ctry, question, question_text, order) %>%
  multi_boot_standard("response", na.rm = T) %>%
  ungroup() %>% 
  ggplot(aes(x = epi_ctry, y = mean, color = epi_ctry)) +
  facet_wrap(~ reorder(str_wrap(question_text, 90), order), ncol = 3) +
  geom_jitter(data = d_spex_base_q22to23, aes(y = response), 
              height = 0.05, alpha = 0.08, show.legend = F) +
  geom_pointrange(aes(ymin = ci_lower, ymax = ci_upper), 
                  position = position_dodge(width = 0.5), 
                  color = "black", show.legend = F) +
  scale_color_brewer(palette = "Dark2") +
  scale_y_continuous(breaks = seq(0, 1, 0.25)) +
  theme(axis.text.x = element_text(angle = 45, hjust = 1, vjust = 1)) +
  labs(title = "Spiritual experiences #22-23: Responses to individual items",
       subtitle = "Error bars are bootstrapped 95% CIs",
       x = "Site", 
       y = "Mean response, i.e., prop. responding 'yes'\n(0 = no, 1 = yes)")
```


<P style="page-break-before: always">
# Relationships between porosity and spiritual experience

Finally, I will consider the relationship between Porosity scores and Spiritual Experience scores, comparing this relationship across sites and examining this relationship within each site indivdidually. Again, I will explore two ways of handling the discrepancy between questions asked in Thailand vs. other sites.

## Considering all "beings" (more for Thailand)

```{r}
d_por_spex_base_q2to23_propall <- d_spex_base_q2to23_scored_propall %>% 
  rename(spex_score_propall = score) %>%
  full_join(d_por_scored %>% rename(por_score = score)) %>%
  group_by(epi_ctry) %>%
  mutate(por_score_std = scale(por_score),
         spex_score_propall_std = scale(spex_score_propall)) %>%
  ungroup() %>%
  mutate(por_score_std_collapse = scale(por_score),
         spex_score_propall_std_collapse = scale(spex_score_propall))

# effect-code by default
contrasts(d_por_spex_base_q2to23_propall$epi_ctry) <- contr.sum(5)
```

```{r, fig.width = 4, fig.asp = 0.35, include = F}
ggplot(d_por_spex_base_q2to23_propall,
       aes(x = por_score, y = spex_score_propall, color = epi_ctry)) +
  facet_grid(~ epi_ctry) +
  geom_point(alpha = 0.2, show.legend = F) +
  geom_smooth(method = "lm", color = "black", show.legend = F) +
  scale_x_continuous(breaks = seq(0, 16, 4)) +
  scale_y_continuous(breaks = seq(0, 1, 0.25)) +
  scale_color_brewer(palette = "Dark2") +
  labs(title = "Relationship between porosity and spiritual experience",
       subtitle = "Includes all beings for Thailand",
       x = "Porosity score (0-16)",
       y = "Spiritual experience\nproportion score (0-1)")
```

```{r, fig.width = 4, fig.asp = 0.3, include = T}
ggplot(d_por_spex_base_q2to23_propall,
       aes(x = por_score_std_collapse, y = spex_score_propall_std_collapse, 
           color = epi_ctry)) +
  facet_wrap(~ epi_ctry, ncol = 5, scales = "free") +
  geom_point(alpha = 0.2, show.legend = F) +
  geom_smooth(method = "lm", color = "black", show.legend = F) +
  scale_x_continuous(breaks = seq(-4, 4, 1)) +
  scale_y_continuous(breaks = seq(-4, 4, 1)) +
  scale_color_brewer(palette = "Dark2") +
    labs(title = "Relationship between porosity and spiritual experience",
       subtitle = "Includes all beings for Thailand",
       x = "Porosity score (standardized collapsing across sites)",
       y = "Spiritual exp. proportion score\n(std. collapsing across sites)")
```

From the plot, it is clear that there is a general relationship between Porosity and Spiritual Experience scores. The strength of this relationships appears to vary somewhat across sites, but visual inspection suggests that this relationship is present to some degree in each site individually. 

First, I'll look at this relationship considering all sites in the same analysis (standardizing scores collapsing across all sites, to maintain the pattern fo general differences in Porosity and Spiritual Experience across sites):

```{r}
r_por_spex_propall <- lm(por_score_std_collapse ~ spex_score_propall_std_collapse * epi_ctry,
                         d_por_spex_base_q2to23_propall,
                         contrasts = list(epi_ctry = contrasts_ctry_ctr))
```

```{r, include = T}
summary(r_por_spex_propall)$coefficients %>%
  data.frame() %>%
  rownames_to_column("parameter") %>%
  rename(b = Estimate, `standard error` = Std..Error, `t` = t.value,
         p = Pr...t..) %>%
  mutate_at(vars(-parameter, -p), funs(round(., 2))) %>%
  mutate(p = ifelse(p < 0.001, "<0.001", round(p, 3)),
         significant = ifelse(p < 0.05, "*", "")) %>%
  kable(align = c("l", rep("r", 5), "l"),
        caption = "Relationship between porosity and spiritual experience, comparing across sites [model: lm(por_score_std_collapse ~ spex_score_propall_std_collapse * epi_ctry, d_por_spex_base_q2to23_propall)]") %>%
  kable_styling() %>%
  row_spec(c(2, 7:10), bold = T)
```

Including all of the data in a single analysis suggests that, collapsing across sites, the relationship between Porosity and Spiritual Experience scores is significantly positive (see "spex_score_propall_std" row in the table above). However, this relationship appears to be significantly weaker among participants outside of the US than it is among US participants (see "spex_score_propall_std:epi_ctrynonUS_US" row), significantly weaker among participants in Ghana and Vanuatu relative to participants in Thailand and China (see "spex_score_propall_std:epi_ctryGHVT_THCH" row), and significantly weaker among participants in Ghana relative to participants in Vanuatu (see "spex_score_propall_std:epi_ctryGH_VT" row). In other words, the relationship between Porosity and Spiritual Experience seems to have been strongest in the US and Chinese samples, weaker in the ni-Van and Thai samples, and weakest in the Ghanaian sample. (This is true even after accounting for overall differences in porosity and spiritual experience across sites.)

<P style="page-break-before: always">
```{r, fig.width = 4, fig.asp = 0.3, include = T}
ggplot(d_por_spex_base_q2to23_propall,
       aes(x = por_score_std, y = spex_score_propall_std, color = epi_ctry)) +
  facet_wrap(~ epi_ctry, ncol = 5, scales = "free") +
  geom_point(alpha = 0.2, show.legend = F) +
  geom_smooth(method = "lm", color = "black", show.legend = F) +
  # scale_x_continuous(breaks = seq(0, 16, 4)) +
  # scale_y_continuous(breaks = seq(0, 22, 4)) +
  scale_color_brewer(palette = "Dark2") +
    labs(title = "Relationship between porosity and spiritual experience",
       subtitle = "Includes all beings for Thailand",
       x = "Porosity score (standardized within each site)",
       y = "Spiritual exp. proportion score\n(standardized within each site)")
```

```{r, fig.width = 4, fig.asp = 0.35, include = F}
ggplot(d_por_spex_base_q2to23_propall %>%
         filter(abs(por_score_std) < 2,
                abs(spex_score_propall_std) < 2),
       aes(x = por_score_std, y = spex_score_propall_std, color = epi_ctry)) +
  facet_wrap(~ epi_ctry, ncol = 5) +
  geom_point(alpha = 0.2, show.legend = F) +
  geom_smooth(method = "lm", color = "black", show.legend = F) +
  # scale_x_continuous(breaks = seq(0, 16, 4)) +
  # scale_y_continuous(breaks = seq(0, 22, 4)) +
  scale_color_brewer(palette = "Dark2") +
  labs(title = "Relationship between porosity and spiritual experience",
       subtitle = "Includes all beings for Thailand\nExcluding outliers (z > 2 or z < -2)",
       x = "Porosity score (standardized within each site)",
       y = "Spiritual exp. proportion score\n(standardized within each site)")
```

Next, I'll look at this relationship considering each sites individually in its own analysis (standardizing scores within each site):

```{r}
r_por_spex_propall_us <- lm(por_score_std ~ spex_score_propall_std,
                           d_por_spex_base_q2to23_propall %>%
                             filter(epi_ctry == "US"))

r_por_spex_propall_gh <- lm(por_score_std ~ spex_score_propall_std,
                           d_por_spex_base_q2to23_propall %>%
                             filter(epi_ctry == "Ghana"))

r_por_spex_propall_th <- lm(por_score_std ~ spex_score_propall_std,
                           d_por_spex_base_q2to23_propall %>%
                             filter(epi_ctry == "Thailand"))

r_por_spex_propall_ch <- lm(por_score_std ~ spex_score_propall_std,
                           d_por_spex_base_q2to23_propall %>%
                             filter(epi_ctry == "China"))

r_por_spex_propall_vt <- lm(por_score_std ~ spex_score_propall_std,
                           d_por_spex_base_q2to23_propall %>%
                             filter(epi_ctry == "Vanuatu"))
```

```{r, include = T}
rbind(summary(r_por_spex_propall_us)$coefficients %>%
        data.frame() %>%
        rownames_to_column("parameter") %>%
        mutate(site = "US"),
      summary(r_por_spex_propall_gh)$coefficients %>%
        data.frame() %>%
        rownames_to_column("parameter") %>%
        mutate(site = "Ghana"),
      summary(r_por_spex_propall_th)$coefficients %>%
        data.frame() %>%
        rownames_to_column("parameter") %>%
        mutate(site = "Thailand"),
      summary(r_por_spex_propall_ch)$coefficients %>%
        data.frame() %>%
        rownames_to_column("parameter") %>%
        mutate(site = "China"),
      summary(r_por_spex_propall_vt)$coefficients %>%
        data.frame() %>%
        rownames_to_column("parameter") %>%
        mutate(site = "Vanuatu")) %>%
  rename(b = Estimate, `standard error` = Std..Error, `t` = t.value,
         p = Pr...t..) %>%
  mutate_at(vars(-c(parameter, p, site)), funs(round(., 2))) %>%
  mutate(p = ifelse(p < 0.001, "<0.001", round(p, 3)),
         significant = ifelse(p < 0.05, "*", "")) %>%
  select(-site) %>%
  kable(align = c("l", rep("r", 5), "l"),
        caption = "Relationship between porosity and spiritual experience, within each site separately [model: lm(por_score_std ~ spex_score_propall_std, d_por_spex_base_q2to23_propall %>% filter(epi_ctry == ...)]") %>%
  kable_styling() %>%
  group_rows("US", 1, 2) %>%
  group_rows("Ghana", 3, 4) %>%
  group_rows("Thailand", 5, 6) %>%
  group_rows("China", 7, 8) %>%
  group_rows("Vanuatu", 9, 10) %>%
  row_spec(c(seq(2, 10, 2)), bold = T)
```

This analysis suggests that the relationship between Porosity and Spiritual Experience is signficantly positive in all five sites considered individually. The regression coefficients ("b" column in the table above) further confirm that the strength of this relationhip varied across sites: It was strongest in China and the US, middling in Vanuatu and Thailand, and weakest (but still significantly positive) in Ghana.

<P style="page-break-before: always">
## Considering first five "beings" for all sites

```{r}
d_por_spex_base_q2to23_first5 <- d_spex_base_q2to23_scored_first5 %>% 
  rename(spex_score_first5 = score) %>%
  full_join(d_por_scored %>% rename(por_score = score)) %>%
  group_by(epi_ctry) %>%
  mutate(por_score_std = scale(por_score),
         spex_score_first5_std = scale(spex_score_first5)) %>%
  ungroup() %>%
  mutate(por_score_std_collapse = scale(por_score),
         spex_score_first5_std_collapse = scale(spex_score_first5))

# effect-code by default
contrasts(d_por_spex_base_q2to23_first5$epi_ctry) <- contr.sum(5)
```

```{r, fig.width = 4, fig.asp = 0.35, include = F}
ggplot(d_por_spex_base_q2to23_first5,
       aes(x = por_score, y = spex_score_first5, color = epi_ctry)) +
  facet_grid(~ epi_ctry) +
  geom_point(alpha = 0.2, show.legend = F) +
  geom_smooth(method = "lm", color = "black", show.legend = F) +
  scale_x_continuous(breaks = seq(0, 16, 4)) +
  scale_y_continuous(breaks = seq(0, 22, 2)) +
  scale_color_brewer(palette = "Dark2") +
  labs(title = "Relationship between porosity and spiritual experience",
       subtitle = "Includes first five beings for all sites",
       x = "Porosity score (0-16)",
       y = "Spiritual exp. sum score (0-22)")
```

```{r, fig.width = 4, fig.asp = 0.3, include = T}
ggplot(d_por_spex_base_q2to23_first5,
       aes(x = por_score_std_collapse, y = spex_score_first5_std_collapse, 
           color = epi_ctry)) +
  facet_wrap(~ epi_ctry, ncol = 5, scales = "free") +
  geom_point(alpha = 0.2, show.legend = F) +
  geom_smooth(method = "lm", color = "black", show.legend = F) +
  scale_x_continuous(breaks = seq(-4, 4, 1)) +
  scale_y_continuous(breaks = seq(-4, 4, 1)) +
  scale_color_brewer(palette = "Dark2") +
    labs(title = "Relationship between porosity and spiritual experience",
       subtitle = "Includes first five beings for all sites",
       x = "Porosity score (standardized collapsing across sites)",
       y = "Spiritual exp. sum score\n(std. collapsing across sites)")
```

Again, it is clear from the plot that there is a general relationship between Porosity and Spiritual Experience scores, and the strength of this relationships appears to vary somewhat across sites. 

First, I'll look at this relationship considering all sites in the same analysis (standardizing scores collapsing across all sites, to maintain the pattern fo general differences in Porosity and Spiritual Experience across sites):

```{r}
r_por_spex_first5 <- lm(por_score_std_collapse ~ spex_score_first5_std_collapse * epi_ctry,
                         d_por_spex_base_q2to23_first5,
                         contrasts = list(epi_ctry = contrasts_ctry_ctr))
```

```{r, include = T}
summary(r_por_spex_first5)$coefficients %>%
  data.frame() %>%
  rownames_to_column("parameter") %>%
  rename(b = Estimate, `standard error` = Std..Error, `t` = t.value,
         p = Pr...t..) %>%
  mutate_at(vars(-parameter, -p), funs(round(., 2))) %>%
  mutate(p = ifelse(p < 0.001, "<0.001", round(p, 3)),
         significant = ifelse(p < 0.05, "*", "")) %>%
  kable(align = c("l", rep("r", 5), "l"),
        caption = "Relationship between porosity and spiritual experience, comparing across sites [model: lm(por_score_std_collapse ~ spex_score_first5_std_collapse * epi_ctry, d_por_spex_base_q2to23_first5)]") %>%
  kable_styling() %>%
  row_spec(c(2, 7:10), bold = T)
```

This analysis is virtually identical to the parallel analysis using proportion scores, above—with the additional suggestion that the relationship was significantly weaker among participants in Thailand than participants in China (see "spex_score_first5_std:epi_ctryTH_CH" row in table above).

```{r, fig.width = 4, fig.asp = 0.3, include = T}
ggplot(d_por_spex_base_q2to23_first5,
       aes(x = por_score_std, y = spex_score_first5_std, color = epi_ctry)) +
  facet_wrap(~ epi_ctry, ncol = 5, scales = "free") +
  geom_point(alpha = 0.2, show.legend = F) +
  geom_smooth(method = "lm", color = "black", show.legend = F) +
  # scale_x_continuous(breaks = seq(0, 16, 4)) +
  # scale_y_continuous(breaks = seq(0, 22, 4)) +
  scale_color_brewer(palette = "Dark2") +
    labs(title = "Relationship between porosity and spiritual experience",
       subtitle = "Includes first five beings for all sites",
       x = "Porosity score (standardized within each site)",
       y = "Spiritual exp. sum score\n(standardized within each site)")
```

```{r, fig.width = 4, fig.asp = 0.35, include = F}
ggplot(d_por_spex_base_q2to23_first5 %>%
         filter(abs(por_score_std) < 2,
                abs(spex_score_first5_std) < 2),
       aes(x = por_score_std, y = spex_score_first5_std, color = epi_ctry)) +
  facet_wrap(~ epi_ctry, ncol = 5) +
  geom_point(alpha = 0.2, show.legend = F) +
  geom_smooth(method = "lm", color = "black", show.legend = F) +
  # scale_x_continuous(breaks = seq(0, 16, 4)) +
  # scale_y_continuous(breaks = seq(0, 22, 4)) +
  scale_color_brewer(palette = "Dark2") +
  labs(title = "Relationship between porosity and spiritual experience",
       subtitle = "Includes first five beings for all sites\nExcluding outliers (z > 2 or z < -2)",
       x = "Porosity score (standardized within each site)",
       y = "Spiritual exp. sum score\n(standardized within each site)")
```

Next, I'll look at this relationship considering each sites individually in its own analysis (standardizing scores within each site):

```{r}
r_por_spex_first5_us <- lm(por_score_std ~ spex_score_first5_std,
                           d_por_spex_base_q2to23_first5 %>%
                             filter(epi_ctry == "US"))

r_por_spex_first5_gh <- lm(por_score_std ~ spex_score_first5_std,
                           d_por_spex_base_q2to23_first5 %>%
                             filter(epi_ctry == "Ghana"))

r_por_spex_first5_th <- lm(por_score_std ~ spex_score_first5_std,
                           d_por_spex_base_q2to23_first5 %>%
                             filter(epi_ctry == "Thailand"))

r_por_spex_first5_ch <- lm(por_score_std ~ spex_score_first5_std,
                           d_por_spex_base_q2to23_first5 %>%
                             filter(epi_ctry == "China"))

r_por_spex_first5_vt <- lm(por_score_std ~ spex_score_first5_std,
                           d_por_spex_base_q2to23_first5 %>%
                             filter(epi_ctry == "Vanuatu"))
```

```{r, include = T}
rbind(summary(r_por_spex_first5_us)$coefficients %>%
        data.frame() %>%
        rownames_to_column("parameter") %>%
        mutate(site = "US"),
      summary(r_por_spex_first5_gh)$coefficients %>%
        data.frame() %>%
        rownames_to_column("parameter") %>%
        mutate(site = "Ghana"),
      summary(r_por_spex_first5_th)$coefficients %>%
        data.frame() %>%
        rownames_to_column("parameter") %>%
        mutate(site = "Thailand"),
      summary(r_por_spex_first5_ch)$coefficients %>%
        data.frame() %>%
        rownames_to_column("parameter") %>%
        mutate(site = "China"),
      summary(r_por_spex_first5_vt)$coefficients %>%
        data.frame() %>%
        rownames_to_column("parameter") %>%
        mutate(site = "Vanuatu")) %>%
  rename(b = Estimate, `standard error` = Std..Error, `t` = t.value,
         p = Pr...t..) %>%
  mutate_at(vars(-c(parameter, p, site)), funs(round(., 2))) %>%
  mutate(p = ifelse(p < 0.001, "<0.001", round(p, 3)),
         significant = ifelse(p < 0.05, "*", "")) %>%
  select(-site) %>%
  kable(align = c("l", rep("r", 5), "l"),
        caption = "Relationship between porosity and spiritual experience, within each site separately [model: lm(por_score_std ~ spex_score_first5_std, d_por_spex_base_q2to23_first5 %>% filter(epi_ctry == ...)]") %>%
  kable_styling() %>%
  group_rows("US", 1, 2) %>%
  group_rows("Ghana", 3, 4) %>%
  group_rows("Thailand", 5, 6) %>%
  group_rows("China", 7, 8) %>%
  group_rows("Vanuatu", 9, 10) %>%
  row_spec(c(seq(2, 10, 2)), bold = T)
```

As with the analysis of proportion scores, this analysis suggests that the relationship between Porosity and Spiritual Experience is signficantly positive in all five sites considered individually, and the regression coefficients ("b" column in the table above) further confirm that this relationhip was strongest in China and the US, middling in Vanuatu and Thailand, and weakest (but still significantly positive) in Ghana.


